## 2024 Digital IC Design

## Homework 3: matrix multiplier

| NAME                       |                                    |           |            |                                      |                                                                                                                                              |                            |       |  |
|----------------------------|------------------------------------|-----------|------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------|--|
| Student II                 | ) N2                               | N26124264 |            |                                      |                                                                                                                                              |                            |       |  |
| Simulation Result          |                                    |           |            |                                      |                                                                                                                                              |                            |       |  |
| Functional simulation      | 100                                |           | 100        | Clock<br>width                       | 22                                                                                                                                           | Gate-level simulation time | 88374 |  |
| Pattern 3 pass             |                                    |           |            |                                      | # 4:Pattern 1054 is PASS ! # 1:Pattern 1055 is PASS ! # 1:Pattern 1056 is PASS ! # Pattern 3 pass # Simulation FINISH !! # soore = 100/100 # |                            |       |  |
| Synthesis Result           |                                    |           |            |                                      |                                                                                                                                              |                            |       |  |
| Total logic elements       |                                    |           |            | 1206                                 |                                                                                                                                              |                            |       |  |
| Total men                  |                                    |           | 0          |                                      |                                                                                                                                              |                            |       |  |
| Embedded                   | er 9-bit elem                      | ent       | 5          | 5                                    |                                                                                                                                              |                            |       |  |
| Flow                       |                                    | 9         | Successful | uccessful - Sat May 11 18:57:38 2024 |                                                                                                                                              |                            |       |  |
| Quar                       | Quartus Prime Version              |           |            |                                      | 20.1.1 Build 720 11/11/2020 SJ Lite Edition                                                                                                  |                            |       |  |
| Revision Name              |                                    |           |            | ММ                                   |                                                                                                                                              |                            |       |  |
| Тор-                       | Top-level Entity Name              |           |            |                                      | ММ                                                                                                                                           |                            |       |  |
| Family                     |                                    |           |            | Cyclone IV E                         |                                                                                                                                              |                            |       |  |
| Device E                   |                                    |           |            | EP4CE55F23A7                         |                                                                                                                                              |                            |       |  |
| Timing Models F            |                                    |           |            | Final                                |                                                                                                                                              |                            |       |  |
| Total logic elements       |                                    |           |            | 1,206 / 55,856 ( 2 % )               |                                                                                                                                              |                            |       |  |
| Total registers            |                                    |           |            | 317                                  |                                                                                                                                              |                            |       |  |
| Tota                       | Total pins                         |           |            |                                      | 36 / 325 (11 %)                                                                                                                              |                            |       |  |
| Tota                       | Total virtual pins                 |           |            |                                      | 0                                                                                                                                            |                            |       |  |
| Total                      | Total memory bits                  |           |            |                                      | 0 / 2,396,160 ( 0 % )                                                                                                                        |                            |       |  |
| Emb                        | Embedded Multiplier 9-bit elements |           |            | 5 / 308 (2 %)<br>0 / 4 (0 %)         |                                                                                                                                              |                            |       |  |
| Tota                       | l PLLs                             |           |            |                                      |                                                                                                                                              |                            |       |  |
| Description of your design |                                    |           |            |                                      |                                                                                                                                              |                            |       |  |

在這次的作業中我使用 7 個 counter,有兩個記錄輸入 matrix1、2 的列與欄位數,並用一個 counter 記錄輸出總數,其餘兩個用於記錄每個矩陣輸入數量,在後續 check 的 state 時確定輸入資料數量都有正確。



圖 1 FSM 流程圖

在每個 state 時,FSM 會依據下一個狀態是甚麼決定目前需要做的事情,因為第一個直送進去的時間與 rst 降下來的時間相同,若不用下一個狀態提前執行會錯過第一個輸入的數值。

在 next 為 data\_to\_matrix1 與 data\_to\_matrix1\_end 時會將輸入的值存入 matrix1 ,增加 end 是因為怕最後一個值被略過因此增加的 ,next 為 data\_to\_matrix2 與 data\_to\_matrix2\_end 時,會將輸入的值儲存至 matrix2,接著會在 next 為 check 時檢查是否 matrix1、2 的值數量是否與 col、row 相成的數量相同,並檢查兩矩陣是否可以相乘,若不能相乘則回到 idle 狀態,可以的話進行相乘動作,並一一將所有數值相乘後輸出。

 $Scoring = (1206 + 0 + 9*5) \times (88374) = 110555874$ 

 $Scoring = (Total\ logic\ elements + total\ memory\ bit + 9*embedded\ multiplier\ 9-bit\ element) \times (Total\ cycle\ used*clock\ width)$